<template>
  <div class="assign_role">
    <el-dialog title="分配角色" :visible="showAssignRoleDialog" @close="btnCancel">
      <!-- 复选框组件 -->
      <el-checkbox-group v-model="roleIds">
        <el-checkbox v-for="item in list" :key="item.id" :label="item.id">{{ item.name }}</el-checkbox>
      </el-checkbox-group>
      <!-- 确定和取消按钮 -->
      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="btnOk">确 定</el-button>
        <el-button @click="btnCancel">取 消</el-button>
      </div>
      <!-- <el-row slot="footer" type="flex" justify="center">
        <el-col>
          <el-button type="primary" size="small">确 定</el-button>
          <el-button size="small">取 消</el-button>
        </el-col>
      </el-row> -->
    </el-dialog>
  </div>
</template>

<script>
// 导入获取所有的角色列表的方法
import { getAllRolesLists } from '@/api/setting.js';
// 导入获取用户基本信息的接口
import { getUserBaseInfo } from '@/api/user.js';
// 导入给员工分配权限的方法
import { assignRoles } from '@/api/employee.js';
export default {
  props: {
    showAssignRoleDialog: {
      type: Boolean,
      default: false,
    },
    userId: {
      type: String,
      default: null,
    },
  },
  data() {
    return {
      // 所有的角色列表
      list: [],
      // 当前id所对应、的用户的拥有的角色列表
      roleIds: [],
    };
  },
  created() {
    this.getAllRolesLists();
  },
  methods: {
    // 获取所有角色信息
    async getAllRolesLists() {
      const { rows } = await getAllRolesLists({
        // 不传值默认取10条数据
        page: 1,
        pagesize: 20,
      });
      this.list = rows;
      // console.log(this.list);
    },
    // 获取用户的基本信息,由于这个方法是在弹出对话框就调用的，因此userId是从父组件传值传过来的，这个过程是异步的
    // 因此这个方法要在父组件中通过this.$refs.getUserBaseInfo(id) 来调用
    async getUserBaseInfo(id) {
      const { roleIds } = await getUserBaseInfo(id);
      this.roleIds = roleIds;
    },
    async btnOk() {
      await assignRoles({ id: this.userId, roleIds: this.roleIds });
      // 关闭对话框
      this.$emit('update:showAssignRoleDialog', false);
    },
    btnCancel() {
      // 清空角色数组
      this.roleIds = [];
      // 关闭对话框
      this.$emit('update:showAssignRoleDialog', false);
    },
  },
};
</script>

<style>

</style>
